UI专项-元素定位方式和思考
作者:邹德龙
编稿:庄锦弟
前言:
要做好UI自动化测试,做好元素定位很重要,也经常收到反馈说定位难,但是有些东西是可以提炼出来共同点的。接下来简单看看android和ios可以分别怎么定位,以及实践UI自动化以来提炼的思想:
一、Android定位
前置: adb命令、python3、可开启开发者选项的安卓手机
工具: WEditor(支持windows/Mac双平台)
安装: 安装weditor,在终端中输入
pip install weditor
元素定位开始:
1、手机连接安卓设备(安卓设备得开启USB调试),部分手机得启用视图属性检查功能。
2、通过adb devices
获取到机器的设备号
3、启动weditor,执行
python -m weditor
4、启动成功后页面
1)选择android
2)输入adb devices
获取的设备号
3)点击connect
按钮可链接设备,这时候设备会弹出软件安装申请,选择安装选项
5、打开想要抓取元素的APP的页面,点击 Dump Hierarchy
按钮刷新页面,抓取页面元素,若想切换别的页面抓取,操作APP后点击刷新按钮即可。
报错解决:
1、如果启动报错:atx-agent recover failed
pip install --upgrade --pre uiautomator2
二、IOS定位
前置: python3、装有WDA的Iphone手机
工具: tidevice 、appium 1.21.0
安装:
1、安装tidevice,在终端中输入
pip install tidevice
2、appium 官网下载安装即可(装最新版本)
元素定位开始:
1、tidevice applist
查看安装应用程序同时查看设备上的第三方应用包名,若提示信任弹窗,点击信任
2、连接iOS设备,查看连接设备命令,查看设备UDID:
tidevice list
采坑点:可能碰到驱动问题点电脑无法正常连接手机设备,可下载爱思助手工具自动修复驱动
3、启动WDA
tidevice -u 设备UDID wdaproxy -B WDA包名 -p 8200
设备UDID :注意替换为自己设备UDID(例如:0000xxxxxxx ) WDA包名:替换wda为自己的包名(例如:xxxx.xctrunner) 启动成功:
4、打开appium,注意为1.20.2版本及以上,启动服务器
5、开始元素定位
1)打开appium启动服务,点击File - New Session Windows
- 输入JSON Reoresentation
参数 - 启动会话
JSON Reoresentation
示例:
{
"deviceName": "xxxx", # 通用 - 关于手机 - 名称
"bundleId": "xxxxx", # 应用包名
"platformversion": "14.4", # 手机版本
"udid": "000080xxxxxxxxxxxE", # UDID
"webDriverAgentUrl": "http://localhost:8200",
"platformName": "IOS",
"xcodeOrgId": "xxxxxx", # xcodeOrgId
"automationName": "XCUITest",
"usePrebuiltWDA": true,
"useXctestrunFile": false,
"skipLogCapture": true
}
2)启动成功后即可开始抓取元素
三、提炼思想
大道至简:用简单好用高效的元素定位:
Android :id > text > img > ocr > xpath
IOS : name > text > img > ocr > xpath
Web/H5:name > id > text > selector
网络延迟:finds 框架方法(查找元素设置超时时间,间隔性扫描元素若元素存在则执行下一步,若超过指定时长未查找到元素则为失败,推荐使用),element_is_existed
框架方法(设置元素最长寻找时间,找到元素则返回True
,未找到元素则返回False
)
模糊匹配:不要在一棵树上吊死,模糊匹配,不同版本中text
元素(例如原价、秒杀价等)可能只有部分文案变化部分文案固定不变,可用模糊匹配命中。
总结:
元素定位是UI自动化的基础能力,先有元素后有操作。 元素定位方式的选择决定了Case的执行效率和稳定性, 也决定了哪些功能可以通过UI自动化实现覆盖。 WEditor、Appium inspector 等只是获取定位方式的工具。 如果你想要做好元素定位,推荐大家多多学习各种控件的特性、实现方式 和 页面布局思想~